
<template>
  <div id="china-map" style="width: 100%; height: 600px;"></div>
</template>

<script>
import * as echarts from 'echarts';
import chinaMapData from "../../assets/data.json";
export default {
  name: 'ChinaMap',
  data() {
    return {
      mapData: [
        {
          name: '北京',
          value: 8,
          schools: ['北京大学', '清华大学', '中国人民大学', '北京理工大学', '北京航空航天大学', '北京师范大学', '中国农业大学', '中央民族大学']
        },
        {
          name: '上海',
          value: 4,
          schools: ['复旦大学', '上海交通大学', '同济大学', '华东师范大学']
        },
        {
          name: '安徽',
          value: 1,
          schools: ['中国科学技术大学']
        },
        {
          name: '福建',
          value: 1,
          schools: ['厦门大学']
        },
        {
          name: '甘肃',
          value: 1,
          schools: ['兰州大学']
        },
        {
          name: '广东',
          value: 4,
          schools: ['中山大学', '华南理工大学', '哈尔滨工业大学（深圳）', '北京师范大学（珠海校区）']
        },
        {
          name: '河北',
          value: 1,
          schools: ['东北大学秦皇岛分校']
        },
        {
          name: '黑龙江',
          value: 1,
          schools: ['哈尔滨工业大学']
        },
        {
          name: '湖北',
          value: 2,
          schools: ['武汉大学', '华中科技大学']
        },
        {
          name: '湖南',
          value: 3,
          schools: ['国防科技大学', '中南大学', '湖南大学']
        },
        {
          name: '辽宁',
          value: 3,
          schools: ['大连理工大学（盘锦校区）', '东北大学', '大连理工大学']
        },
        {
          name: '吉林',
          value: 1,
          schools: ['吉林大学']
        },
        {
          name: '天津',
          value: 2,
          schools: ['南开大学', '天津大学']
        },
        {
          name: '江苏',
          value: 3,
          schools: ['南京大学', '东南大学', '中国人民大学（苏州校区）']
        },
        {
          name: '浙江',
          value: 2,
          schools: ['浙江大学', '浙江大学医学院']
        },
        {
          name: '山东',
          value: 4,
          schools: ['山东大学', '中国海洋大学', '山东大学（威海）', '哈尔滨工业大学（威海）']
        },
        {
          name: '四川',
          value: 3,
          schools: ['四川大学','电子科技大学','电子科技大学（沙河校区）']
        },
        {
          name: '重庆',
          value: 1,
          schools: ['重庆大学']
        },
        {
          name: '陕西',
          value: 3,
          schools: ['西安交通大学', '西北工业大学', '西北农林科技大学']
        },
      ]
    };
  },
  mounted() {
    this.initChart();
  },
  methods: {
    initChart() {
      echarts.registerMap('china', chinaMapData);
      const chart = echarts.init(document.getElementById('china-map'));
      const option = {
        title: {
          text: '',
          left: 'center'
        },
        tooltip: {
          trigger: 'item',
          formatter: (params) => {
            const province = this.mapData.find(p => p.name === params.name);
            if (province) {
              return `${params.name}（${params.value}所）：<br/>${province.schools.join('<br/>')}`;
            } else {
              return `${params.name}：无985高校`;
            }
          }
        },
        visualMap: {
          min: 0,
          max: 10,
          left: 'left',
          top: 'bottom',
          text: ['高', '低'], // 文本，默认为数值文本
          inRange: {
            color: ['#e0ffff', '#006edd']
          },
          show: true
        },
        series: [
          {
            name: '985高校数量',
            type: 'map',
            mapType: 'china',
            roam: false,
            label: {
              show: true
            },
            data: this.mapData.map(province => ({
              name: province.name,
              value: province.value
            }))
          }
        ]
      };
      chart.setOption(option);
    }
  }
};
</script>

<style scoped>
#china-map {
  width: 100%;
  height: 600px;
}
</style>
